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class Carltem { // these properties are mapped to a database table 
public string ID 
public string Vin; 
public string Color; 
public decimal Cost; 
... many others omitted ... 

} 

class Dealer { // these properties are mapped to a different database table 
public string ID; 
public string City; 
public string State; 
... many others omitted ... 



AdHocQueryCriteria adHocCriteria = Criteria. AdHocQueryCriteria( 

Criteria.EntityAliases( // describes the objects involved in the query 

Criteria.EntityAlias(itemParentKey, typeof(CarItem)) 

Criteria.EntityAlias(dealerParentKey, typeof(Dealer)) ), 
Criteria. JoinList( 

/* entity to entity join */ 

Criteria.IimerJoin("CarItem", "Dealer", 

(Property)"Caritem.DealerID" = (Property)"Dealer.ID")), 

Criteria. Select( // the specific properties to retrieve 

(Property)"CarItem.ID", // references the field in the above class 

(Property)"CarItem.Vin", 

(Property)"CarItem.Cost", 

(Property)"Dealer.ID", 

(Property)"Dealer.City", 

(Property)"Dealer.State")> 
Criteria. Where( ~ — — — — - 

(Property)"CarItem.Make" = "Geo" && 

(Property)"CarItem.Model" == "Prism" && 

(Property)"Dealer.State" = "ND") 
Criteria.OrderBy((Property)"Dealer.Cost")); 
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212 



1002 

class Order { // these fields are mapped to a database table public string ID; 



public DetailCollection Details; // contains Detail objectspublic decimal Total;} 
1004 class Detail t M these fields are mapped to a database table 
i public long SequenceNumber; 

V public Item Item; 

public decimal PricePerUnit; 
public decimal Quantity; 
1006 public decimal Price; // PricePerUnit * Quantity} 

// the user describes the set operation they want performed in terms of objects 
Criteria.EntitySetUpdateCriteria(Criteria.EntityAlias(parentKey, typeof(Order))), 
1010 J/ update the order// set Order.Total to the sum of each of the line item's price 

v. CriteriaPropertyAssignments(Criteria.Assignment((Property) ,, Order.Totar', 
100^ Criteria.Sum((Property)"Order.Details[].Price") ) 
v. // indicates which orders to update; only those with detail price > 300 
Criteria. Where((Property) 5, Order.OrderDetails[] .Price" > 300),) 
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